-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Python lint: Ruff rules for pylint and code complexity #525
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Conversation
8690e74
to
1d06973
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for contributing to Python SDK!
- Please can you provide rationale for the specific numerical thresholds chosen
- Is implementing both C90 and PL linting rules simultaneously necessary?
- Please remove the widespread import style changes which aren't central to the linting goals
The subprocess check=False change is great, but should be submitted as a separate PR focused on that specific fix.
A subset of: * modelcontextprotocol#525 % `ruff check --select=PLW1510` ``` 1 PLW1510 [*] subprocess-run-without-check ``` https://docs.astral.sh/ruff/rules/subprocess-run-without-check
1d06973
to
7628dcb
Compare
Please read the git commit when reviewing pull requests.
The current code complexity determines the values set in this PR, with comments showing the recommended values. If you want to find complexity in the codebase, then lower any of these values by one and run - mccabe.max-complexity = 13 # Default is 10
- max-branches = 14 # Default is 12
- max-returns = 7 # Default is 6
- max-statements = 69 # Default is 50
+ mccabe.max-complexity = 24 # Default is 10
+ max-branches = 23 # Default is 12
+ max-returns = 13 # Default is 6
+ max-statements = 99 # Default is 50 I have the RUFF settings to ignore the pylint import rules PLC0414 and PLR0402. |
Add ruff rules for Pylint and McCabe cyclomatic code complexity.
%
ruff check --select=C90,PL --statistics | sort -k2
Motivation and Context
Pylint checks for errors, enforces a coding standard, looks for code smells, and can suggest how code could be refactored.
McCabe detects functions with high complexity that are hard to understand and maintain.
The C90 and PLR091 rules enable the setting of upper limits on code complexity. If a contributor wants to raise these limits, that can lead to useful discussion in code reviews about why complexity needs to rise and maintainability needs to go down.
How Has This Been Tested?
Breaking Changes
Types of changes
Checklist
Additional context